#### Microprogrammed Control

# MICROPROGRAMMED CONTROL

- Control Memory
- Sequencing Microinstructions
- Microprogram Example
- Design of Control Unit
- Microinstruction Format
- Nanostorage and Nanoprogram

Computer Organization

Computer Architectures Lab

Microprogrammed Control

3

# **TERMINOLOGY**

#### Microprogram

- Program stored in memory that generates all the control signals required to execute the instruction set correctly
- Consists of microinstructions

#### Microinstruction

- Contains a control word and a sequencing word
   Control Word All the control information required for one clock cycle
   Sequencing Word Information needed to decide
   the next microinstruction address
- Vocabulary to write a microprogram

# **Control Memory(Control Storage: CS)**

- Storage in the microprogrammed control unit to store the microprogram

#### Writeable Control Memory(Writeable Control Storage:WCS)

- CS whose contents can be modified
  - -> Allows the microprogram can be changed
  - -> Instruction set can be changed or modified

#### **Dynamic Microprogramming**

- Computer system whose control unit is implemented with a microprogram in WCS
- Microprogram can be changed by a systems programmer or a user

Computer Organization

Computer Architectures Lab



#### Microprogrammed Control

4

# **TERMINOLOGY**

## Sequencer (Microprogram Sequencer)

- A Microprogram Control Unit that determines the Microinstruction Address to be executed in the next clock cycle
  - In-line Sequencing
  - Branch
  - Conditional Branch
  - Subroutine
  - Loop
  - Instruction OP-code mapping

Computer Organization













# Microprogrammed Control 10 Microprogram MACHINE INSTRUCTION FORMAT Machine instruction format

### Sample machine instructions

I Opcode

| Symbol   | OP-code | Description                                |  |  |
|----------|---------|--------------------------------------------|--|--|
| ADD      | 0000    | AC ← AC + M[EA]                            |  |  |
| BRANCH   | 0001    | if (AC < 0) then (PC ← EA)                 |  |  |
| STORE    | 0010    | M[EA] ← AC                                 |  |  |
| EXCHANGE | 0011    | $AC \leftarrow M[EA], M[EA] \leftarrow AC$ |  |  |

Address

EA is the effective address

#### **Microinstruction Format**



F1, F2, F3: Microoperation fields CD: Condition for branching BR: Branch field AD: Address field

Computer Organization

Computer Architectures Lab

Microprogrammed Control

12

Microprogram

# MICROINSTRUCTION FIELD DESCRIPTIONS - CD, BR

| CD | Condition Symbol |     | Comments             |  |  |
|----|------------------|-----|----------------------|--|--|
| 00 | Always = 1       | U   | Unconditional branch |  |  |
| 01 | DR(15)           | - 1 | Indirect address bit |  |  |
| 10 | AC(15)           | S   | Sign bit of AC       |  |  |
| 11 | AC = 0           | Z   | Zero value in AC     |  |  |

| BR | Symbol | Function                                                 |  |  |  |  |
|----|--------|----------------------------------------------------------|--|--|--|--|
| 00 | JMP    | CAR ← AD if condition = 1                                |  |  |  |  |
|    |        | CAR ← CAR + 1 if condition = 0                           |  |  |  |  |
| 01 | CALL   | CAR ← AD, SBR ← CAR + 1 if condition = 1                 |  |  |  |  |
|    |        | CAR ← CAR + 1 if condition = 0                           |  |  |  |  |
| 10 | RET    | CAR ← SBR (Return from subroutine)                       |  |  |  |  |
| 11 | MAP    | $CAR(2-5) \leftarrow DR(11-14), CAR(0,1,6) \leftarrow 0$ |  |  |  |  |

Computer Organization

# SYMBOLIC MICROINSTRUCTIONS

- · Symbols are used in microinstructions as in assembly language
- A symbolic microprogram can be translated into its binary equivalent by a microprogram assembler.

Sample Format

five fields: label: micro-ops: CD: BR: AD

Label: may be empty or may specify a symbolic

address terminated with a colon

Micro-ops: consists of one, two, or three symbols separated by commas

CD: one of {U, I, S, Z}, where **U: Unconditional Branch** 

I: Indirect address bit

S: Sign of AC

Z: Zero value in AC

BR: one of {JMP, CALL, RET, MAP}

one of {Symbolic address, NEXT, empty} AD:

Computer Organization

Computer Architectures Lab

Microprogrammed Control

Microprogram

# SYMBOLIC MICROPROGRAM

- · Control Storage: 128 20-bit words
- The first 64 words: Routines for the 16 machine instructions
- The last 64 words: Used for other purpose (e.g., fetch routine and other subroutines)
- OP-code XXXX into 0XXXX00, the first address for the 16 routines are · Mapping: 0(0 0000 00), 4(0 0001 00), 8, 12, 16, 20, ..., 60

Partial Symbolic Microprogram

| Label            | Microops                                                 | CD                  | BR                              | AD                               |  |
|------------------|----------------------------------------------------------|---------------------|---------------------------------|----------------------------------|--|
| ADD:             | ORG 0<br>NOP<br>READ<br>ADD                              | U<br>U              | CALL<br>JMP<br>JMP              | INDRCT<br>NEXT<br>FETCH          |  |
| BRANCH:<br>OVER: | ORG 4<br>NOP<br>NOP<br>NOP<br>ARTPC                      | S<br>U<br>I<br>U    | JMP<br>JMP<br>CALL<br>JMP       | OVER<br>FETCH<br>INDRCT<br>FETCH |  |
| STORE:           | ORG 8<br>NOP<br>ACTDR<br>WRITE                           | I<br>U<br>U         | CALL<br>JMP<br>JMP              | INDRCT<br>NEXT<br>FETCH          |  |
| EXCHANGE:        | ORG 12<br>NOP<br>READ<br>ACTDR, DRTAC<br>WRITE           | <br> <br> <br> <br> | CALL<br>JMP<br>JMP<br>JMP       | INDRCT<br>NEXT<br>NEXT<br>FETCH  |  |
| FETCH:           | ORG 64<br>PCTAR<br>READ, INCPC<br>DRTAR<br>READ<br>DRTAR | U<br>U<br>U         | JMP<br>JMP<br>MAP<br>JMP<br>RET | NEXT<br>NEXT                     |  |

Computer Organization

Computer Architectures Lab

# **SYMBOLIC MICROPROGRAM - FETCH ROUTINE**

During FETCH, Read an instruction from memory and decode the instruction and update PC

Sequence of microoperations in the fetch cycle:

AR ← PC

Microprogrammed Control

DR ← M[AR], PC ← PC + 1

 $AR \leftarrow DR(0-10), CAR(2-5) \leftarrow DR(11-14), CAR(0,1,6) \leftarrow 0$ 

Symbolic microprogram for the fetch cycle:

ORG 64 FETCH:

**PCTAR** 

U JMP NEXT READ, INCPC U JMP NEXT

DRTAR U MAP

Binary equivalents translated by an assembler

| Binary address | F1  | F2  | F3  | CD | BR | AD      |
|----------------|-----|-----|-----|----|----|---------|
| 1000000        | 110 | 000 | 000 | 00 | 00 | 1000001 |
| 1000001        | 000 | 100 | 101 | 00 | 00 | 1000010 |
| 1000010        | 101 | 000 | 000 | 00 | 11 | 0000000 |

Computer Organization

Computer Architectures Lab

Microprogrammed Control

Microprogram

# **BINARY MICROPROGRAM**

|               | Address |         |     | Binary | Binary Microinstruction |    |    |         |
|---------------|---------|---------|-----|--------|-------------------------|----|----|---------|
| Micro Routine | Decimal | Binary  | F1  | F2     | F3                      | CD | BR | AD      |
| ADD           | 0       | 0000000 | 000 | 000    | 000                     | 01 | 01 | 1000011 |
|               | 1       | 0000001 | 000 | 100    | 000                     | 00 | 00 | 0000010 |
|               | 2       | 0000010 | 001 | 000    | 000                     | 00 | 00 | 1000000 |
|               | 3       | 0000011 | 000 | 000    | 000                     | 00 | 00 | 1000000 |
| BRANCH        | 4       | 0000100 | 000 | 000    | 000                     | 10 | 00 | 0000110 |
|               | 5       | 0000101 | 000 | 000    | 000                     | 00 | 00 | 1000000 |
|               | 6       | 0000110 | 000 | 000    | 000                     | 01 | 01 | 1000011 |
|               | 7       | 0000111 | 000 | 000    | 110                     | 00 | 00 | 1000000 |
| STORE         | 8       | 0001000 | 000 | 000    | 000                     | 01 | 01 | 1000011 |
|               | 9       | 0001001 | 000 | 101    | 000                     | 00 | 00 | 0001010 |
|               | 10      | 0001010 | 111 | 000    | 000                     | 00 | 00 | 1000000 |
|               | 11      | 0001011 | 000 | 000    | 000                     | 00 | 00 | 1000000 |
| EXCHANGE      | 12      | 0001100 | 000 | 000    | 000                     | 01 | 01 | 1000011 |
|               | 13      | 0001101 | 001 | 000    | 000                     | 00 | 00 | 0001110 |
|               | 14      | 0001110 | 100 | 101    | 000                     | 00 | 00 | 0001111 |
|               | 15      | 0001111 | 111 | 000    | 000                     | 00 | 00 | 1000000 |
| FETCH         | 64      | 1000000 | 110 | 000    | 000                     | 00 | 00 | 1000001 |
|               | 65      | 1000001 | 000 | 100    | 101                     | 00 | 00 | 1000010 |
|               | 66      | 1000010 | 101 | 000    | 000                     | 00 | 11 | 0000000 |
| INDRCT        | 67      | 1000011 | 000 | 100    | 000                     | 00 | 00 | 1000100 |
|               | 68      | 1000100 | 101 | 000    | 000                     | 00 | 10 | 0000000 |

This microprogram can be implemented using ROM

Computer Organization









# MICROINSTRUCTION FORMAT

Information in a Microinstruction

- Control Information
- Sequencing Information
- Constant

Information which is useful when feeding into the system

These information needs to be organized in some way for

- Efficient use of the microinstruction bits
- Fast decoding

#### Field Encoding

- Encoding the microinstruction bits
- Encoding slows down the execution speed due to the decoding delay
- Encoding also reduces the flexibility due to the decoding hardware

Computer Organization

Computer Architectures Lab

Microprogrammed Control

23

Control Storage Hierarchy

# NANOSTORAGE AND NANOINSTRUCTION

The decoder circuits in a vertical microprogram storage organization can be replaced by a ROM

=> Two levels of control storage

First level - Control Storage Second level - Nano Storage

Two-level microprogram

First level

-Vertical format Microprogram

Second level

- -Horizontal format Nanoprogram
- Interprets the microinstruction fields, thus converts a vertical microinstruction format into a horizontal nanoinstruction format.

Usually, the microprogram consists of a large number of short microinstructions, while the nanoprogram contains fewer words with longer nanoinstructions.

Computer Organization

Computer Architectures Lab

# HORIZONTAL AND VERTICAL MICROINSTRUCTION FORMAT

#### **Horizontal Microinstructions**

Microprogrammed Control

Each bit directly controls each micro-operation or each control point

Horizontal implies a long microinstruction word

Advantages: Can control a variety of components operating in parallel.

--> Advantage of efficient hardware utilization

Disadvantages: Control word bits are not fully utilized

--> CS becomes large --> Costly

**Vertical Microinstructions** 

A microinstruction format that is not horizontal

Vertical implies a short microinstruction word

**Encoded Microinstruction fields** 

--> Needs decoding circuits for one or two levels of decoding



Computer Organization

Computer Architectures Lab

Microprogrammed Control

24

Control Storage Hierarchy

# TWO-LEVEL MICROPROGRAMMING - EXAMPLE

- \* Microprogram: 2048 microinstructions of 200 bits each
- \* With 1-Level Control Storage: 2048 x 200 = 409,600 bits
- \* Assumption:

256 distinct microinstructions among 2048

\* With 2-Level Control Storage:

Nano Storage: 256 x 200 bits to store 256 distinct nanoinstructions

Control storage: 2048 x 8 bits

To address 256 nano storage locations 8 bits are needed

\* Total 1-Level control storage: 409.600 bits

Total 2-Level control storage: 67,584 bits (256 x 200 + 2048 x 8)



Computer Organization